package com.shujuwuliankeji.ems.cloud.module.system.service;

import java.util.List;
import java.util.Set;

import com.shujuwuliankeji.ems.cloud.module.system.domain.SysUserRole;
import com.shujuwuliankeji.ems.cloud.system.api.domain.SysRole;

/**
 * 角色业务层
 * 
 * @author ruoyi
 */
public interface ISysRoleService {
	/**
	 * 根据条件分页查询角色数据
	 * 
	 * @param role 角色信息
	 * @return 角色数据集合信息
	 */
	public List<SysRole> selectRoleList(SysRole role);

	/**
	 * 根据用户ID查询角色列表
	 * 
	 * @param userId 用户ID
	 * @return 角色列表
	 */
	public List<SysRole> selectRolesByUserId(Long userId);

	/**
	 * 根据用户ID查询角色权限
	 * 
	 * @param userId 用户ID
	 * @return 权限列表
	 */
	public Set<String> selectRolePermissionByUserId(Long userId);

	/**
	 * 查询所有角色
	 * 
	 * @return 角色列表
	 */
	public List<SysRole> selectRoleAll();

	/**
	 * 根据用户ID获取角色选择框列表
	 * 
	 * @param userId 用户ID
	 * @return 选中角色ID列表
	 */
	public List<Long> selectRoleListByUserId(Long userId);

	/**
	 * 通过角色ID查询角色
	 * 
	 * @param roleId 角色ID
	 * @return 角色对象信息
	 */
	public SysRole selectRoleById(Long roleId);

	/**
	 * 校验角色名称是否唯一
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public String checkRoleNameUnique(SysRole role);

	/**
	 * 校验角色权限是否唯一
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public String checkRoleKeyUnique(SysRole role);

	/**
	 * 校验角色是否允许操作
	 * 
	 * @param role 角色信息
	 */
	public void checkRoleAllowed(SysRole role);

	/**
	 * 校验角色是否有数据权限
	 * 
	 * @param roleId 角色id
	 */
	public void checkRoleDataScope(Long roleId);

	/**
	 * 通过角色ID查询角色使用数量
	 * 
	 * @param roleId 角色ID
	 * @return 结果
	 */
	public int countUserRoleByRoleId(Long roleId);

	/**
	 * 新增保存角色信息
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public int insertRole(SysRole role);

	/**
	 * 修改保存角色信息
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public int updateRole(SysRole role);

	/**
	 * 修改角色状态
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public int updateRoleStatus(SysRole role);

	/**
	 * 修改数据权限信息
	 * 
	 * @param role 角色信息
	 * @return 结果
	 */
	public int authDataScope(SysRole role);

	/**
	 * 通过角色ID删除角色
	 * 
	 * @param roleId 角色ID
	 * @return 结果
	 */
	public int deleteRoleById(Long roleId);

	/**
	 * 批量删除角色信息
	 * 
	 * @param roleIds 需要删除的角色ID
	 * @return 结果
	 */
	public int deleteRoleByIds(Long[] roleIds);

	/**
	 * 取消授权用户角色
	 * 
	 * @param userRole 用户和角色关联信息
	 * @return 结果
	 */
	public int deleteAuthUser(SysUserRole userRole);

	/**
	 * 批量取消授权用户角色
	 * 
	 * @param roleId  角色ID
	 * @param userIds 需要取消授权的用户数据ID
	 * @return 结果
	 */
	public int deleteAuthUsers(Long roleId, Long[] userIds);

	/**
	 * 批量选择授权用户角色
	 * 
	 * @param roleId  角色ID
	 * @param userIds 需要删除的用户数据ID
	 * @return 结果
	 */
	public int insertAuthUsers(Long roleId, Long[] userIds);

	/**
	 * 获取SaaS角色
	 * 
	 * @return
	 */
	public List<SysRole> saasRole();

	/**
	 * 根据userId查询用户角色
	 * 
	 * @param userId
	 * @return
	 */
	public List<Long> saasRoleSelected(Long userId);

	/**
	 * 根据用户userId删除 角色关联表
	 * 
	 * @param userId
	 * @return
	 */
	public int deleteSaasRole(Long userId);

	/**
	 * 根据userIds删除 关联表role
	 * 
	 * @param userIds
	 * @return
	 */
	public int deleteSaasRoleByUserIds(Long[] userIds);
}
